package com.jingdianjichi.club.gateway.auth;

import cn.dev33.satoken.context.SaHolder;
import cn.dev33.satoken.reactor.filter.SaReactorFilter;
import cn.dev33.satoken.router.SaRouter;
import cn.dev33.satoken.stp.StpUtil;
import cn.dev33.satoken.util.SaResult;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;

/**
 * @BelongsProject: jc-club
 * @BelongsPackage: com.jingdianjichi.club.gateway.auth
 * @Author: liyajun
 * @CreateTime: 2025-08-16  15:15
 * @Description: SaToken配置类,权限认证配置器
 * @Version: 1.0
 */
@Configuration
public class SaTokenConfigure {
    // 注册 Sa-Token全局过滤器
    @Bean
    public SaReactorFilter getSaReactorFilter() {
        return new SaReactorFilter()
                // 拦截地址
                .addInclude("/**")    /* 拦截全部path */
                // 开放地址
                .addExclude("/favicon.ico")
                // 鉴权方法：每次访问进入
                .setAuth(obj -> {
                    System.out.println("-------- 前端访问path：" + SaHolder.getRequest().getRequestPath());
//                    StpUtil.checkLogin();
                    System.out.println("-------- 此 path 校验成功：" + SaHolder.getRequest().getRequestPath());
                    // 登录校验 -- 拦截所有路由，并排除/user/doLogin 用于开放登录
                    //SaRouter.match("/auth/**", "/auth/user/doLogin", r -> StpUtil.checkRole("admin"))
//                            .match("/auth/**", "/auth/user/register",r -> StpUtil.checkLogin())
                    ;
                //    SaRouter.match("/auth/**",  "/auth/user/register", r -> StpUtil.checkLogin());
                    SaRouter.match("/oss/**",  r -> StpUtil.checkLogin());
                    SaRouter.match("/subject/subject/add",  r -> StpUtil.checkPermission("subject:add"));
                    SaRouter.match("/subject/**",  r -> StpUtil.checkLogin());
                    // 更多匹配 ...  */
                });
//                // 异常处理方法：每次setAuth函数出现异常时进入
//                .setError(e -> {
//                    return SaResult.error(e.getMessage());
//                });
    }
}
